A TECHNIQUE OF GENERATING 



A COMPOSITE MEDIA STREAM 

1. Field of the Invention. 

This invention relates in general to computer implemented systems, and more 
5 particularly, to a technique for generating a composite media stream. 

2. Description of Related Art . 

The Internet is a vast collection of global- spanning networks that communicate 
with each other by using protocols, such as the Transmission Control Protocol (TCP) and 
the Internet Protocol (IP). Via its networks, the Internet enables many computers, located 
10 at different sites around the world, to access information from each other. 

The World Wide Web (i.e., the "WWW" or the "Web") is the fastest growing part 
of the Internet. The Web contains Web pages that incorporate text, graphics, sound, 
animation, and other multimedia elements. Each Web page is formatted in a language 
called HyperText Markup Language (HTML). Hypertext links connect the web pages to 
15 each other, and to any other pages, graphics, binary files, or multimedia files. 

The Web works within a client/server model. Web client software runs on the 
Web client computers, and Web server software runs on the Web server computer. Web 
client software - known as the Web browser - interacts with both the user and the Web 
server software. In particular, the Web browser receives a Universal Resource Locator 
20 (URL) request from a user. The URL is a unique identifier for requested information 
(e.g., a web page, a document, or an object). The Web browser then sends the URL 
request to the Web server software using Hypertext Transfer Protocol (HTTP). In 
response to the URL request, the Web server software locates and returns the requested 
information to the Web browser. 

25 One of the most exciting aspects of the Web is the multimedia content. Users can 

access audio files and listen to music, sound clips or live (and archived) radio stations 
from their computers via Web pages. The Web server computer typically sends these 
audio files to the Web client computer by using a technique called streaming audio. 
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Streaming audio allows a user to play sounds and music on the Web client computer 
while the Web server computer is sending the file. Accordingly, the user does not have to 
wait until the entire audio file is downloaded before listening to the audio. 

With respect to Internet radio stations, users typically select a particular Internet 
5 radio station from an Internet radio Web page. Many Internet radio Web pages contain 
textual descriptions of certain Internet radio stations which can be accessed from their 
pages. These textual descriptions allow users to search for an appealing Internet radio 
station by reading and analyzing text. These textual descriptions are similar to the 
seek/scan feature provided by many conventional on-air broadcast radio systems because 
1 0 they allow users to preview the Internet radio station's programming and/or format. 

The key difference between the textual descriptions and the conventional 
seek/scan feature is that the seek/scan feature allows a user to search for an appealing 
broadcast radio station by listening to samples of music. When the listener hears an 
appealing sample of music, the listener can perform an action, such as clicking a button, 
1 5 which tunes the broadcast radio system to the desired broadcast radio station. The current 
Internet radio Web pages lack this tuning by ear technique. Thus, there is a need in the 
art for an improved technique of searching for Internet radio stations. 

SUMMARY OF THE INVENTION 

To overcome the limitations in the prior art described above, and to overcome 
20 other limitations that will become apparent upon reading and understanding the present 
specification, the present invention discloses a method, apparatus, and article of 
manufacture for providing information. 

According to one embodiment of the present invention, at least two data segments 
are collected. Each data segment is collected from a media stream, and each media 
25 stream is located at a different media source. Then, a composite media stream is 
generated by joining together each of the collected data segments. In another 
embodiment, the data segment is an audio data segment. 

The above-described invention has utility for allowing a user/listener to search for 
a media source (e.g., an Internet radio station) by listening to a composite media stream. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Referring now to the drawings in which like reference numbers represent 
corresponding parts throughout: 

FIG. 1 is a schematic diagram illustrating a hardware environment used to 
5 implement a server computer in one embodiment of the invention; 

FIG. 2 is a schematic diagram illustrating a hardware environment used to 
implement a client computer in one embodiment of the invention; 

FIG. 3 is a schematic diagram illustrating a client/server computer environment of 
an embodiment of the present invention; 

10 FIG. 4 is a flow diagram illustrating the process performed by the Scanstream 

System. 

DETAILED DESCRIPION 

In the following description of embodiments of the invention, reference is made to 
the accompanying drawings which form a part hereof, and which is shown by why of 
15 illustration, a specific embodiment in which the invention may be practiced. It is to be 
understood that other embodiments may be utilized as structural changes may be made 
without departing from the scope of the present invention. 

This invention is comprised of a collection of components, which will be referred 
to herein as the "Scanstream System." It is to be understood that these components may 
20 be combined in many different ways to form a variety of combinations within the scope 
of the invention. Generally, the Scanstream System receives media streams from media 
sources that stream audio via the Internet. 

For each media stream, the Scanstream System samples a segment of the media 
stream. The segment can be a multimedia data segment that has a pre-defined time 
25 duration (e.g., five seconds). The Scanstream System then affixes each data segment with 
an identification tag, and digitizes both the data segment and the identification tag 
(referred to collectively as the digitized data). Next, the Scanstream System transmits the 
digitized data to a client computer. 
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The Scanstream System performs this sequence for each media stream. When the 
Scanstream System reaches the last media stream, it cycles back to the first media stream 
and repeats the sequence. Therefore, the Scanstream System transmits a composite media 
stream that contains digitized data from different media sources to a client computer. To 
5 put it differently, the Scanstream system creates a composite media stream by joining 
together data segments from different sources. 

The client computer plays and/or displays this composite media stream, together 
with the identification tags, such that each identification tag is simultaneously displayed 
and/or played with its associated data segment. At this point, a user can interrupt the 
10 composite media stream to select an appealing media data segment by using an input 
device (e.g., a mouse, keyboard, stylus or some other input device). 

In response to such selection, the Scanstream System links the client computer 
directly to the media stream associated with the selected media data segment. More 
specifically, the Scanstream System disconnects the client computer from the composite 
1 5 media stream, and connects the client computer to the media stream associated with the 
selected media data segment. The media stream associated with the selected media 
segment can be transmitted by any media source, such as an Internet radio station. The 
user can listen to the media stream associated with the selected media data segment or 
the user can resume listening to the composite media stream. 

20 It is noted that the Scanstream System constantly transmits one or more different 

composite streams. This transmission process is independent of the number of client 
computers that might be receiving a composite media stream at a given point in time. 
There could be anywhere from zero client computers to an infinite number of client 
computers receiving a particular composite media stream, at a given point in time. 

25 One advantageous feature of the Scanstream System includes allowing a user to 

search for and/or scan media sources by listening to samples of music from each media 
source. In particular, at the client computer, the user will hear and/or see a progression of 
short samples of longer media streams that emanate from different media sources. 

Before providing the details of the Scanstream System, the hardware 

30 environments used to implement a client computer and a server computer in one 

embodiment of the present invention are discussed. 

4 

LAI J16004v2 



Hardware 



FIG 1 is a schematic diagram illustrating a hardware environment used to 
implement a server computer 100 in one embodiment of the invention. The present 
invention is typically implemented using a server computer 100, which generally includes 
5 a processor 102, a random access memory (RAM) 104, data storage devices 106 (e.g., 
hard, floppy, and/or CD-ROM disk, drives, etc.) data communications devices 108 (e.g., 
modems, network interfaces, etc.), display devices 110 (e.g., CRT, LCD display, etc.), 
and input devices 112 (e.g., mouse pointing device, keyboard, CD-ROM drive, etc.). It is 
envisioned that attached to the server computer 100 may be other devices, such as read 
10 only memory (ROM), a video card, bus interface, printers, etc. Those skilled in the art 
will recognize that any combination of the above components, or any number of different 
components, peripherals, and other devices, may be used with the server computer 100. 

The server computer 100 operates under the control of an operating system (OS) 
114. The operating system 114 is booted into the memory 104 of the server computer 

15 100 for execution when the server computer 100 is powered-on or reset. In turn, the 
operating system 114 then controls the execution of one or more computer programs 1 16, 
such as the controller software for managing the Scanstream System and the encoder 
software for digitizing media streams. The present invention is generally implemented in 
these computer programs 116, which execute under the control of the operating system 

20 114, and cause the server computer 100 to perform the desired functions as described 
herein. 

The operating system 114 and computer programs 116 are comprised of 
instructions which, when read and executed by the server computer 100, cause the server 
computer 100 to perform the steps necessary to implement and/or use the present 

25 invention. Generally, the operating system 114 and/or computer programs 116 are 
tangibly embodied in and/or readable from a device, carrier, or media such as memory 
104, data storage devices 106, and/or data communications devices 108. Under control of 
the operating system 114, the computer programs 116 may be loaded from the memory 
104, data storage devices 106, and/or data communications devices 208 into the memory 

30 204 of the server computer 100 for use during actual operations. 
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Thus, the present invention may be implemented as a method, apparatus, or article 
of manufacture using standard programming and/or engineering techniques to produce 
software, firmware, hardware, or any combination thereof. The term "article of 
manufacture" (or alternatively, "computer program product") as used herein, is intended 
5 to encompass a computer program accessible from any computer-readable device, carrier, 
or media. Of course, those skilled in the art will recognize many modifications may be 
made to this configuration without departing from the scope of the present invention. 

Those skilled in the art will also recognize that the environment illustrated in FIG. 
1 is not intended to limit the present invention. Indeed, those skilled in the art will 
10 recognize that other alternative hardware environments may be used without departing 
from the scope of the present invention. 

FIG 2 is a schematic diagram illustrating a hardware environment used to 
implement a client computer 200 in one of the invention. The present invention is 
typically implemented using a client computer 200, which generally includes a processor 

15 202, a random access memory (RAM) 204, data storage devices 206 (e.g., hard, floppy, 
and/or CD-ROM disk, drives, etc.), data communications devices 208 (e.g., modems, 
network interfaces, etc.), display devices 210 (e.g., CRT, LCD display, etc.), and input 
devices 212 (e.g., mouse pointing device, keyboard, CD-ROM drive, etc.). It is 
envisioned that attached to the client computer 200 may be other devices, such as read 

20 only memory (ROM), a video card, bus interface, printers, etc. Those skilled in the art 
will recognize that any combination of the above components, or any number of different 
components, peripherals, and other devices, may be used with the client computer 200. 

The client computer 200 operates under the control of an operating system (OS) 
214. The operating system 214 is booted into the memory 204 of the client computer 

25 200 for execution when the client computer 200 is powered-on or reset. In turn, the 
operating system 214 then controls the execution of one or more computer programs 216, 
such as software to receive and play/display media streams. The present invention is 
generally implemented in these computer programs 216, which execute under the control 
of the operating system 214, and cause the client computer 200 to perform the desired 

30 functions as described herein. 
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The operating system 214 and computer programs 216 are comprised of 
instructions which, when read and executed by the client computer 200, cause the client 
computer 200 to perform the steps necessary to implement and/or use the present 
invention. Generally, the operating system 214 and/or computer programs 216 are 
5 tangibly embodied in and/or readable from a device, carrier, or media such as memory 
204, data storage devices 206, and/or data communications devices 208. Under control of 
the operating system 114, the computer programs 116 may be loaded from the memory 
204, data storage devices 206, and/or data communication devices 208 into the memory 
204 of the client computer 200 for use during actual operations. 

10 Thus, the present invention may be implemented as a method, apparatus or article 

of manufacture, using standard programming and/or engineering techniques to produce 
software, firmware, hardware, or any combination thereof. The term "article of 
manufacture" (or alternatively, "computer program product") as used herein, is intended 
to encompass a computer program accessible from any computer-readable device, carrier, 

15 or media. Of course, those skilled in the are will recognize many modifications may be 
made to this configuration without departing from the scope of the present invention. 

Those skilled in the art will also recognize that the environment illustrated in FIG. 
2 is not intended to limit the present invention. Indeed, those skilled in the art will 
recognize that other alternative hardware environments may be used without departing 
20 from the scope of the present invention. 

Generating A Composite Media Stream 

FIG. 3 is a schematic diagram illustrating a client/server computer environment of 
an embodiment of the present invention, and more particularly, illustrates a typical 
distributed computer system 300 using the Internet to connect the server computer 100 to 
25 the client computer 200. 

The server computer 100 has a controller 302 and an encoder 304. The controller 
302 is connected to a database 306 that contains information about the media sources 
which provide media streams. In FIG. 3, the media sources are Internet radio stations. 
Those skilled in the art will recognize that other media sources may be used without 
30 departing from the scope of the present invention. 
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The information contained in the database 306 is commonly referred to as 
identification tags or as tags. In one embodiment of the present invention, each tag 
consists of multimedia information, including text, graphics, sound, animation, and other 
multimedia elements 

5 The tags may also include identification data, such as the following: the 

identification (ID) number of the Internet radio station; the name of the Internet radio 
station; the geographic location of the Internet radio station; the Stream URL of the 
Internet radio station; and the site URL of the Internet radio station. It is noted that each 
tag may contain two different URLs, the site URL and the stream URL. 

10 The site URL is the address of the Internet radio station's homepage. The stream 

URL contains a small text file (commonly referred to as a metafile) that has the true 
location of the audio file. 

The controller 302 is also connected to server media players 308, 310, 312, 3 14, 
3 16, and 318. The controller 302 is capable of tuning each server media player 308, 310, 
15 312, 314, 316, and 318 to a different Internet radio station, such that each server media 
player 308, 310, 312, 314, 316, and 318 transmits a different media stream to the 
controller 302. 

The controller 302 identifies the number of server media players 308, 310, 312, 
314, 316, and 318. The number of server media players is represented herein by the 
20 variable N. For media player 1 308, the controller 302 fetches an identification tag from 
the database 306. Based on the information contained in the tag, the controller 302 tunes 
media player 1 308 to the Internet radio station identified in the tag. Accordingly, each 
tag is associated with a different Internet radio station. The controller 302 then receives 
media player 1 308's media stream. This media stream may be live or archived. 

25 Next, the controller 302 repeats this sequence of fetching, tuning, and receiving 

for media player 2 310, media player 3 312, media player 4 314, media player 5 316, and 
media player N 318. At this point, each of the server media players 308, 310, 312, 314, 
316 and 318 are tuned into a different Internet radio station, and the controller 302 is 
receiving media streams from each of the server media players 308, 310, 312, 314, 316 

30 and 318. 
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For the media stream provided by media player 1 308, the controller 302 sends 
both the media stream and its associated tag to the encoder 304 for a fixed time duration, 
e.g., five seconds. This fixed time duration could be a pre-defined, default time duration 
or a user-defined time duration. Since, the controller 302 only transmits the media stream 
5 and its associated tag for a fixed time duration, the digitized data is really a data segment 
of a longer media stream. 

The encoder 304 digitizes both the media stream and its associated tag 
(collectively referred to herein as the "digitized data"). The encoder 304 transmits this 
digitized data to the client media player 350, and the client media player 350 sends the 
10 digitized data to the client computer 200. The client computer 200 then plays and/or 
displays the digitized data, such that each data segment and its tag are simultaneously 
displayed to the user. The server computer 100 is connected to the client computer 200 
via the Internet. 

After the fixed time duration, the controller 302 and the encoder 304 perform the 
1 5 same actions on the media stream provided by media player 2 310. That is, the controller 
302 sends both the media stream and its associated tag to the encoder 304 for the fixed 
time duration, and the encoder 304 digitizes the media stream and its associated tag. The 
controller 302 then tunes the previous media player - media player 1 308 - to a new 
Internet radio station, and thus, the controller 302 receives a new media stream from 
20 media player 1 308. The controller 302 and the encoder 304 continue in this manner for 
each media stream, until the controller 302 reaches the media stream provided by media 
player N 3 18. The controller 302 then starts over with the new media stream provided by 
media player 1 308. 

At the client computer 200, a user can interrupt the composite media stream 352 
25 to select an appealing media data segment by using an input device (e.g., a mouse, 
keyboard, stylus or some other input device). The user can make this selection at any 
time during the play and/or display of the composite media stream 352. In response to 
such a selection, the Scanstream System links the user directly to the media stream 
associated with the selected media data segment. More specifically, the Scanstream 
30 System disconnects the user from the composite media stream, and connects the user to 
the media stream associated with the selected media data segment. The user has the 
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option of listening to the media stream associated with the selected media data segment or 
the user can resume listening to the composite media stream 352. 

It is noted that the Scanstream System generates the composite media stream 
when the controller 302 transmits media streams to the encoder 304 for a fixed time 
5 duration. The composite media stream 352 contains data segments 320, 322, 324, 326, 
328, 330, and 332, along with their associated tags 334, 336, 338, 340, 342, 344, and 346. 

In one embodiment of the present invention, the Scanstream System can 
simultaneously transmit two or more different composite media streams, with one 
composite media stream containing samples of Jazz Internet radio stations, and another 

10 composite media stream containing samples of Parisian Internet radio stations. In this 
embodiment, the user can select the type of composite media stream. For example, a user 
can select a composite media stream that contains samples of Rock Internet radio stations. 
A user can also select a composite media stream that contains sample of Internet radio 
stations that are located in Paris. In addition, the user can select a composite media 

15 stream that includes a combination of categories, such as Jazz Internet radio stations and 
News Internet radio stations or any other available combination. 

The Scanstream System will constantly and simultaneously transmit the most 
popular categories, e.g., Jazz, Rock, News, and Rap. For unpopular categories, such as 
Poughkeepsie, a user can request that the Scanstream System create and transmit a 
20 composite media stream containing samples of Poughkeepsie Internet radio stations. 

FIG. 4 is a flow diagram 400 illustrating the process performed by the Scanstream 
System. Block 402 represents the Scanstream System fetching an identification tag from 
the database 306 (shown in FIG. 3). Block 404 represents the Scanstream System tuning 
a server media player 308, 310, 312, 314, 316 or 318 (shown in FIG. 3) to a media 
25 source by using information contained in the identification tag. In particular, the 
Scanstream System tunes the server media player 308, 310, 312, 314, 316 or 318 by 
using the both the stream URL and the site URL. The Scanstream System then receives a 
media stream from the server media player 308, 310, 312, 314, 316 or 318, as 
represented by block 406. 

30 Block 408 is a decision block that represents the Scanstream System determining 

whether there are more server media players 308, 310, 312, 314, 316 or 318 (shown in 

10 
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FIG. 3). When there are more server media players 308, 310, 3 12, 3 14, 3 16, or 3 18, the 
Scanstream System returns to block 402. Otherwise, the Scanstream System proceeds to 
block 410. 

Block 410 represents the Scanstream System initializing the variable N to zero. 
5 The variable N is a variable that represents the number of sever media players. Block 412 
represents the Scanstream System incrementing the variable N by one. 

Block 414 represents the Scanstream System creating a media data segment (or a 
sampling sequence) by digitizing both the media stream received from media player N 
and its associated tag for a fixed time duration. In one embodiment of the present 
10 invention, the fixed time duration is a pre-defined, default time duration. In another 
embodiment, the fixed time duration is a user-defined time duration. 

Block 416 is a decision block that represents the Scanstream System determining 
whether the user has selected a media data segment. When the user selects the media data 
segment, the Scanstream System links the client computer directly to the media stream 
1 5 associated with the selected media data segment, as represented by block 418. Otherwise, 
the Scanstream System proceeds to block 420. 

Block 420 is decision block that represents the Scanstream System determining 
whether there are more server media players. When there are more players, the 
Scanstream system proceeds to block 422. Otherwise, the Scanstream System ends. 

20 Block 422 represents the Scanstream System turning server media player N to a 

new media source. The Scanstream System then returns to block 412. 

Conclusion 

This concludes the description of the preferred embodiment of the invention. The 
following describes some alternative embodiments for accomplishing the present 
25 invention. For example, other hardware environments may include without limitation, 
communications devices, such as appliances, personal digital assistants (PDAs), wrist 
watches, stand alone Internet radios, set top boxes, television systems, mainframe 
computers, minicomputers or personal computers. These may be used in various 
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configurations, such as in a local area network or in conjunction with the Internet. These 
other environments may work with each other or may work independently. 

The foregoing description of the embodiments of the invention have been 
presented for the purposes of illustration and description. It is not intended to be 
exhaustive or to limit the invention to the precise from disclosed. Many modifications 
and variations are possible in light of the above teaching. It is intended that the scope of 
the invention be limited not by this detailed description, but rather by the claims 
appended hereto. 
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